<!DOCTYPE html>
<html>

  <head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

  <title>安卓自定义View教程目录</title>
  <meta name="description" content="自定义View目录，包括自定义坐标系，角度弧度，颜色，自定义view流程，Canvas，Path，PathMeasure，贝塞尔曲线，Matrix，2D绘图等相关内容。">
  <meta name="author" content="GcsSloop">
  <meta name="keywords" content="CustomView, Android, 安卓, 自定义View详解, 自定义控件, Canvas, Path, 贝塞尔曲线, PathMeasure, Matrix, 教程">
  <meta name="关键字" content="CustomView, Android, 安卓, 自定义View详解, 自定义控件, Canvas, Path, 贝塞尔曲线, PathMeasure, Matrix, 教程">
  

  <meta name="twitter:card" content="summary">
  <meta name="twitter:title" content="安卓自定义View教程目录">
  <meta name="twitter:description" content="自定义View目录，包括自定义坐标系，角度弧度，颜色，自定义view流程，Canvas，Path，PathMeasure，贝塞尔曲线，Matrix，2D绘图等相关内容。">
  <meta name="twitter:keywords" content="CustomView, Android, 安卓, 自定义View详解, 自定义控件, Canvas, Path, 贝塞尔曲线, PathMeasure, Matrix, 教程">
  
  <meta property="og:type" content="article">
  <meta property="og:title" content="安卓自定义View教程目录">
  <meta property="og:description" content="自定义View目录，包括自定义坐标系，角度弧度，颜色，自定义view流程，Canvas，Path，PathMeasure，贝塞尔曲线，Matrix，2D绘图等相关内容。">
  <meta name="og:keywords" content="CustomView, Android, 安卓, 自定义View详解, 自定义控件, Canvas, Path, 贝塞尔曲线, PathMeasure, Matrix, 教程">

  <meta name="theme-color" content="#343434">
  
  <link rel="icon" type="image/png" href="https://raw.githubusercontent.com/GcsSloop/gcssloop.github.io/master/assets/siteinfo/favicon.png" />
  <link href="https://raw.githubusercontent.com/GcsSloop/gcssloop.github.io/master/assets/siteinfo/favicon.png" rel="shortcut icon" type="image/png">
  
  <link href="//netdna.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css" rel="stylesheet">
  <link rel="stylesheet" href="/css/main.css">

  <link rel="canonical" href="http://www.gcssloop.com/customview/CustomViewIndex">
  <link rel="alternate" type="application/rss+xml" title="GcsSloop" href="http://www.gcssloop.com/feed.xml">
  
  <meta name="google-site-verification" content="Z_g58PkzRAyBMxkqrcDdWrTBK8oOWM-7rUHauhLNF2E" />
  <meta name="baidu-site-verification" content="kUtTXCKaZs" />
  <meta name="baidu-site-verification" content="6DuDv3aaJX" />
  
  <!--阅读次数统计-->
  <script async src="https://busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"> </script>
  
  <!--Fuck Weixin and Baidu-->
  <meta http-equiv="Cache-Control" content="no-transform">
  <meta http-equiv=”Cache-Control” content=”no-siteapp” />
  <meta name="applicable-device" content="pc,mobile">
  <meta name="HandheldFriendly" content="true"/>

  <!-- Google Ad -->
  <script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
  <script>
    (adsbygoogle = window.adsbygoogle || []).push({
      google_ad_client: "ca-pub-2767831356529421",
      enable_page_level_ads: true
    });
  </script>

</head>


  <body>

    <span class="mobile btn-mobile-menu">
        <i class="fa fa-list btn-mobile-menu__icon"></i>
        <i class="fa fa-angle-up btn-mobile-close__icon hidden"></i>
    </span>
    
    <header class="panel-cover panel-cover--collapsed" style="background-image: url('/assets/siteinfo/background-cover.jpg')">
  <div class="panel-main">

    <div class="panel-main__inner panel-inverted">
    <div class="panel-main__content">

        <a href="/#blog" title="前往 GcsSloop 的主页" class="blog-button"><img src="/assets/siteinfo/avatar.jpg" width="80" alt="GcsSloop logo" class="panel-cover__logo logo" /></a>
        <h1 class="panel-cover__title panel-title"><a href="/#blog" title="link to homepage for GcsSloop" class="blog-button">GcsSloop</a></h1>

        
        <span class="panel-cover__subtitle panel-subtitle">Just do IT later.</span>
        
        <hr class="panel-cover__divider" />
        <p class="panel-cover__description">嗨，我是 GcsSloop，一名来自2.5次元的魔法师，Android自定义View系列文章作者，非著名程序员。</p>
        <hr class="panel-cover__divider panel-cover__divider--secondary" />
        
        
        <p class="panel-cover__description">欢迎来到我的魔法世界!</p>
        
        
        <div class="navigation-wrapper">
          <div>
            <nav class="cover-navigation cover-navigation--primary">
              <ul class="navigation">
                <li class="navigation__item"><a href="/#blog" title="访问博客" class="blog-button">博客</a></li>
                
                  
                    <li class="navigation__item"><a href="https://github.com/GcsSloop" target="_blank" title="GcsSloop's GitHub">GitHub</a></li>
                  
                  
                
                  
                    <li class="navigation__item"><a href="/timeline" title="博客目录">目录</a></li>
                  
                  
                
                  
                    <li class="navigation__item"><a href="https://xiaozhuanlan.com/u/GcsSloop" target="_blank" title="小专栏">专栏</a></li>
                  
                  
                
                  
                    <li class="navigation__item"><a href="/category/customview" title="自定义View教程目录">自定义控件</a></li>
                  
                  
                
                  
                    <li class="navigation__item"><a href="/friends" title="友链">友链</a></li>
                  
                  
                
              </ul>
            </nav>
          </div>
          
          <div><nav class="cover-navigation navigation--social">
  <ul class="navigation">

  
  <!-- Weibo -->
  <li class="navigation__item">
    <a href="http://weibo.com/GcsSloop" title="@GcsSloop 的微博" target="_blank">
      <i class='social fa fa-weibo'></i>
      <span class="label">Weibo</span>
    </a>
  </li>
  

  
  <!-- Github -->
  <li class="navigation__item">
    <a href="https://github.com/GcsSloop" title="@GcsSloop 的 Github" target="_blank">
      <i class='social fa fa-github'></i>
      <span class="label">Github</span>
    </a>
  </li>
  
  
  
  <!-- Twitter -->
  <li class="navigation__item">
    <a href="http://twitter.com/GcsSloop" title="@GcsSloop" target="_blank">
      <i class='social fa fa-twitter'></i>
      <span class="label">Twitter</span>
    </a>
  </li>
  

    

  

  
  <!-- RSS -->
  <li class="navigation__item">
    <a href="/feed.xml" rel="author" title="RSS" target="_blank">
      <i class='social fa fa-rss'></i>
      <span class="label">RSS</span>
    </a>
  </li>
  

  
  <!-- Email -->
  <li class="navigation__item">
    <a href="mailto:GcsSloop@gmail.com" title="发邮件给我">
      <i class='social fa fa-envelope'></i>
      <span class="label">Email</span>
    </a>
  </li>
  

  
  <!-- Copyright -->
  <li class="navigation__item">
    <a href="http://choosealicense.online" title="选择版权"  target="_blank">
      <i class="social fa fa-copyright"></i>
      <span class="label">版权</span>
    </a>
  </li>
  
  
  </ul>
</nav>
</div>
        </div>
      </div>
    </div>
    
    
    <div class="panel-cover--overlay cover-slate"></div>
    
  </div>
</header>


    <div class="content-wrapper">
        <div class="content-wrapper__inner">
            <article class="post-container post-container--single" itemscope itemtype="http://schema.org/BlogPosting">
  <header class="post-header">
    <div class="post-meta" style="font-size:.8em">
      <time datetime="1970-01-03 00:00:00 +0800" itemprop="datePublished" class="post-meta__date date">1970-01-03</time> &#8226; <span class="post-meta__tags tags">自定义View,教程,目录</span> &#8226; View <span id="busuanzi_value_page_pv"></span> times.
</span>
    </div>
    <h1 class="post-title">安卓自定义View教程目录</h1>
  </header>

  <section class="post">
    <p>这是一个从零起步，从入门到懵逼的自定义View教程。本教程从最基础的内容讲解，并且深入到了相关的各个细节，不论你是刚入门的菜鸟，还是有一定经验的工程师相信本系列文章都会对你有所帮助。</p>

<p>你既可以将本教程当作学习资料来学习自定义View相关的各种知识，也可以作为工具来使用，在需要的时候查询相关的知识细节。</p>

<h3 id="基础篇">基础篇</h3>

<ul>
  <li><a href="/customview/CoordinateSystem">安卓自定义View基础 - 坐标系</a></li>
  <li><a href="/customview/AngleAndRadian">安卓自定义View基础 - 角度弧度</a></li>
  <li><a href="/customview/Color">安卓自定义View基础 - 颜色</a></li>
</ul>

<hr />

<h3 id="进阶篇">进阶篇</h3>

<ul>
  <li><a href="/customview/CustomViewProcess">安卓自定义View进阶 - 分类和流程</a></li>
  <li><a href="/customview/Canvas_BasicGraphics">安卓自定义View进阶 - Canvas之绘制图形</a></li>
  <li><a href="/customview/Canvas_Convert">安卓自定义View进阶 - Canvas之画布操作</a></li>
  <li><a href="/customview/Canvas_PictureText">安卓自定义View进阶 - Canvas之图片文字</a></li>
  <li><a href="/customview/Path_Basic">安卓自定义View进阶 - Path之基本操作</a></li>
  <li><a href="/customview/Path_Bezier">安卓自定义View进阶 - Path之贝塞尔曲线</a></li>
  <li><a href="/customview/Path_Over">安卓自定义View进阶 - Path完结篇</a></li>
  <li><a href="/customview/Path_PathMeasure">安卓自定义View进阶 - PathMeasure</a></li>
  <li><a href="/customview/Matrix_Basic">安卓自定义View进阶 - Matrix原理</a></li>
  <li><a href="/customview/Matrix_Method">安卓自定义View进阶 - Matrix详解</a></li>
  <li><a href="/customview/matrix-3d-camera">安卓自定义View进阶 - Matrix Camera</a></li>
  <li><a href="/customview/dispatch-touchevent-theory">安卓自定义View进阶 - 事件分发机制原理</a></li>
  <li><a href="/customview/dispatch-touchevent-source">安卓自定义View进阶 - 事件分发机制详解</a></li>
  <li><a href="/customview/motionevent">安卓自定义View进阶 - MotionEvent详解</a></li>
  <li><a href="/customview/touch-matrix-region">安卓自定义View进阶 - 特殊控件的事件处理方案</a></li>
  <li><a href="/customview/multi-touch">安卓自定义View进阶 - 多点触控详解</a></li>
  <li><a href="/customview/gestruedector">安卓自定义View进阶 - 手势检测(GestureDecetor)</a></li>
  <li><a href="/customview/scalegesturedetector">安卓自定义View进阶 - 缩放手势检测(ScaleGestureDecetor)</a></li>
</ul>

<hr />

<blockquote>
  <p><strong>⚠️ 警告：如果遇到文章中的示例测试结果于文章中效果不同，</strong><br />
<strong>请关闭硬件加速试试，</strong><br />
<strong>请关闭硬件加速试试，</strong><br />
<strong>请关闭硬件加速试试，</strong><br />
<strong>重要的话说三遍。</strong></p>

  <p><strong>如何关闭参考这里 <a href="https://github.com/GcsSloop/AndroidNote/issues/7">Android如何关闭硬件加速</a></strong></p>
</blockquote>

<p><a href="https://github.com/GcsSloop/AndroidNote"><strong>GitHub 版本点这里查看</strong></a></p>

<h3 id="博文修复计划">博文修复计划</h3>

<p>由于自己的知识水平有限，书写的文章难免会出现一些问题。</p>

<p>随着知识增长和知识面的扩大，发现了一些之前未曾注意到的问题，故有此博文修复计划，<strong>本次修复不仅会修复之前文章中的瑕疵和纰漏，甚至会对文章的知识结构稍作调整</strong>，所有修复的文章和调整后的内容都会在微博重新发布声明，点击下面关注我的微博可以第一时间了解到相关信息，另外据说关注我的微博会变帅哦。</p>

<blockquote>
  <p><strong>本次博文修复计划主要针对 个人博客 和 GitHub，由于博主精力有限以及某些平台自身限制，对于其他平台仅能修复部分内容。</strong></p>
</blockquote>

<h3 id="作者微博-gcssloop">作者微博: <a href="http://weibo.com/GcsSloop">@GcsSloop</a></h3>

<p><a href="http://www.gcssloop.com/info/about/" target="_blank"> <img src="http://gcsblog.oss-cn-shanghai.aliyuncs.com/blog/gcs_banner.jpg?gcssloop" width="300" style="display:inline;" /> </a></p>

    <hr>
  </section>
</article>

<!--广告-->

<!--
<div>
<a href="https://m.aliyun.com/act/team1111/?spm=5176.11533457.1089570.5.424777e3AF8WOJ&userCode=hn5smxtw#/" target="_blank"><img src="/assets/aliyun/1111-980-120.jpg" width="100%"></a>
</div>
-->
<!--捐赠晶石-->
<section class="contribute">
    <script type="text/javascript"> 
      function toggle() {
        var con = document.getElementById("contribute");
        if (con.style.display == "none") {
          con.style.display = "block";
        } else {
          con.style.display = "none";
        }
      }
    </script> 
    <blockquote style="background-color:#F5F5F5; padding: 10px 20px 20px 10px; margin:0px" >
      <h4> 如果你觉得我的文章对你有帮助的话，欢迎赞助一些服务器费用! </h4>
      <p></p>
      <a id=“btn-toggle-contribute” class="btn-contribute" onclick="toggle()" >¥ 点击赞助</a>
      <br>
      <div id="contribute" style="display:none;">
        <p align="center" >
        <img src="/assets/images/wechat.png" alt="微信">
        <img src="/assets/images/alipay.png" alt="支付宝">
        </p>
        <p align="left" >
          <b>感谢所有支持我的魔法师，所有支持过我的魔法师都可以通过微信(GcsSloop)联系我，获赠我的付费专栏！</b>
          <!--
          <a href="/contribute">点击这里查看捐赠者名单。</a>
          -->
        </p>
      </div>
    </blockquote>
</section>
<div>
  <h2>欢迎关注我的微信公众号</h2>
  <img src="/assets/images/banner.jpg" width="100%">
</div>

<!--阅读更多-->
<section class="read-more">
  
  
  <div class="read-more-item">
    <span class="read-more-item-dim">最近的文章</span>
    <h2 class="post-list__post-title post-title"><a href="/course/UsePlantUMLInAS(Mac)" title="link to 在AndroidStudio中使用PlantUML(for Mac)">在AndroidStudio中使用PlantUML(for Mac)</a></h2>
    <p class="excerpt">点击下面切换平台:| Mac| Win|Unified Modeling Language (UML)又称统一建模语言或标准建模语言，用来描述 类（对象的）、对象、关联、职责、行为、接口、用例、...&hellip;</p>
    <div class="post-list__meta">
      <time datetime="2015-11-30 00:00:00 +0800" class="post-list__meta--date date">2015-11-30</time> &#8226; <span class="post-list__meta--tags tags">Course</span>
      <br/><br/>
      <a style="float:none; margin:0 auto;" class="btn-border-small" href=/course/UsePlantUMLInAS(Mac)>继续阅读</a></div>
   </div>
   
   
   
   
   <div class="read-more-item">
       <span class="read-more-item-dim">更早的文章</span>
       <h2 class="post-list__post-title post-title"><a href="/info/about" title="link to 关于">关于</a></h2>
       <p class="excerpt">我是 GcsSloop， 一名生活在2.5次元的魔法师，我一直在致力于研究基础魔法，并且始终坚信利用这些基础魔法，可以创造出华丽而又强大的高级魔法。我尝试用很多种方式去分析这些基础魔法，并从中提...&hellip;</p>
       <div class="post-list__meta">
          <time datetime="1970-01-01 08:00:00 +0800" class="post-list__meta--date date">1970-01-01</time> &#8226; <span class="post-list__meta--tags tags">Info</span>
          <br/><br/>
          <a style="float:none; margin:0 auto;" class="btn-border-small" href=/info/about>继续阅读</a>
       </div>
   </div>
   
</section>

<!--网易云跟帖-->
<!--
<div id="cloud-tie-wrapper" class="cloud-tie-wrapper"></div>
<script src="https://img1.cache.netease.com/f2e/tie/yun/sdk/loader.js"></script>
<script>
var cloudTieConfig = {
  url: document.location.href, 
  sourceId: "",
  productKey: "a85dba2840134721a7b69a15b2e0f217",
  target: "cloud-tie-wrapper"
};
var yunManualLoad = true;
Tie.loader("aHR0cHM6Ly9hcGkuZ2VudGllLjE2My5jb20vcGMvbGl2ZXNjcmlwdC5odG1s", true);
</script>
-->

<style type="text/css">
.isso-comment > div.avatar {
    border: 0px;
    box-shadow: none;
    display: block;
    float: left;
    width: 7%;
    margin: 3px 15px 0 0;
}
.isso-postbox > .form-wrapper > .auth-section .post-action > input {
    border-radius: 6px;
    padding: 6px;
    padding-left: 16px;
    padding-right: 16px;
    border: 1px solid #CCC;
    background-color: #D58D44;
    cursor: pointer;
    outline: 0;
    color: #fff;
    size: 10;
    line-height: 1.4em;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}
.isso-postbox > .form-wrapper > .auth-section .post-action > input:hover {
    background-color: #272822;
}
.isso-postbox > .form-wrapper > .auth-section .post-action > input:active {
    background-color: #986530;
}
</style>

<section id="isso-thread"></section>

<script data-isso="//47.52.58.34:1234/"
        data-isso-css="true"
        data-isso-lang="zh"
        data-isso-reply-to-self="false"
        data-isso-require-author="false"
        data-isso-require-email="false"
        data-isso-max-comments-top="10"
        data-isso-max-comments-nested="5"
        data-isso-reveal-on-click="5"
        data-isso-avatar="true"
        data-isso-avatar-bg="#f0f0f0"
        data-isso-avatar-fg="#9abf88 #5698c4 #e279a3 #9163b6 ..."
        data-isso-vote="true"
        data-vote-levels=""
        src="//47.52.58.34:1234/js/embed.min.js">
        </script>

<!--
<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
-->
<!-- OneV's Den -->
<!--
<ins class="adsbygoogle"
     style="display:block"
     data-ad-client="ca-pub-3324997515191619"
     data-ad-slot="9170309685"
     data-ad-format="auto"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
-->

            <section class="footer">
    <footer>
    	<span class="footer__copyright">本站点采用<a rel="license" href="https://creativecommons.org/licenses/by-nc-nd/4.0/deed.zh" target="_blank">知识共享 署名-非商业性使用-禁止演绎 4.0 国际 许可协议</a></span>
        <span class="footer__copyright">本站由 <a href="http://www.GcsSloop.com">@GcsSloop</a> 创建，采用 <a href="https://github.com/GcsSloop/Gcs-Vno-Jekyll" target="_blank">Gcs-Vno-Jekyll</a> 作为主题。<span id="busuanzi_container_site_pv"> 总访问量 <span id="busuanzi_value_site_pv"></span> 次</span> - &copy; 2019</span>
        <span class="footer__sitemap, footer__copyright"><a href="http://www.gcssloop.com/sitemap.xml" target="_blank">Site Map</a>
        <a href="http://www.gcssloop.com/vip" target="_blank">vip</a></span>
    </footer>
</section>

        </div>
    </div>
    
    <script type="text/javascript" src="//code.jquery.com/jquery-1.11.3.min.js"></script>

<script type="text/javascript" src="/js/highlight.pack.js"></script>
<script>hljs.initHighlightingOnLoad();</script>

<script type="text/javascript" src="/js/main.js"></script>

<script>
  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
  (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
  m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
  })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');

  ga('create', 'UA-82493667-1', 'auto');
  ga('send', 'pageview');

</script>

    
  </body>

</html>
